/*
 * To change this template, choose Tools | Templates
 * and open the template in the editor.
 */

package org.cip.esymons.general.bc;

import java.util.List;
import javax.ejb.Stateless;
import javax.persistence.EntityManager;
import javax.persistence.PersistenceContext;
import org.cip.esymons.general.be.Especialidad;
import org.cip.esymons.general.be.Titulo;

/**
 *
 * @author ADMINISTRADOR
 */
@Stateless
public class TituloFacade implements TituloFacadeLocal {
    @PersistenceContext
    private EntityManager em;

    public void create(Titulo titulo) {
        em.persist(titulo);
    }

    public void edit(Titulo titulo) {
        em.merge(titulo);
    }

    public void remove(Titulo titulo) {
        Titulo aux = em.merge(titulo);
        em.remove(aux);
    }

    public Titulo find(Object id) {
        return em.find(Titulo.class, id);
    }

    public List<Titulo> findAll() {
        return em.createQuery("select object(o) from Titulo as o " +
                "order by o.espCodigo.espDescripcion, " +
                "o.titNombre").getResultList();
    }

//    public List<Titulo> findAll() {
//        return em.createQuery("select object(o) from Titulo as o " +
//                "order by o.espCodigo.escuela.facultad.universidad.uniNombre, " +
//                "o.espCodigo.escuela.facultad.facNombre, " +
//                "o.espCodigo.escuela.escNombre, " +
//                "o.espCodigo.espDescripcion, " +
//                "o.titNombre").getResultList();
//    }

    public List<Titulo> buscaPorEspecialidad(Especialidad esp) {
        return em.createQuery("select object(o) from Titulo as o where o.espCodigo=?1").setParameter(1, esp).getResultList();
    }

    public List<Titulo> buscaTituloPorEspecialidad(Integer codigo) {
        return em.createQuery("select object(o) from Titulo as o where o.espCodigo.espCodigo=?1").setParameter(1, codigo).getResultList();
    }

}
